﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Text;
using System.Data;
using CurriculasEntities;

namespace CurriculasDAO
{
    
     public class SilaboDAO : IBaseDA<SilaboBE , int>
    {

         public SilaboBE Crear(SilaboBE entidad)
        {
            using (EFContext db = new EFContext(Utility.ObtenerCadena()))
            {
                db.Silabos.Add(entidad);
                db.SaveChanges();
            }
            return entidad;
        }

         public SilaboBE Obtener(int id)
        {
            using (EFContext db = new EFContext(Utility.ObtenerCadena()))
            {
                return db.Silabos.Find(id);
            }
        }

         public SilaboBE Modificar(SilaboBE entidad)
        {
            using (EFContext db = new EFContext(Utility.ObtenerCadena()))
            {
                db.Silabos.Attach(entidad);
                db.Entry(entidad).State = EntityState.Modified;
                db.SaveChanges();
            }
            return entidad;
        }

         public void Eliminar(SilaboBE entidad)
        {
            using (EFContext db = new EFContext(Utility.ObtenerCadena()))
            {
                db.Silabos.Remove(entidad);
                db.SaveChanges();
            }
        }

         public ICollection<SilaboBE> ListarTodos()
        {
            using (EFContext db = new EFContext(Utility.ObtenerCadena()))
            {
                return db.Silabos.ToList();
            }
        }

         public ICollection<SilaboBE> ListarTodos(Expression<Func<SilaboBE, bool>> where)
        {
            using (EFContext db = new EFContext(Utility.ObtenerCadena()))
            {
                return db.Silabos.Where(where).ToList();
            }
        }

         public ICollection<SilaboBE> DeleteSilabos(int codSilabo)
         {
             string _sentenciaSql = "USP_GC_EliminarSilaboBibliografia " + codSilabo;

             using (EFContext db = new EFContext(Utility.ObtenerCadena()))
             {
                 return db.Database.SqlQuery<SilaboBE>(_sentenciaSql).ToList(); ;
             }
         }
         public ICollection<SilaboBE> BuscarSilaboPeriodo(int codSilabo, int codCurso,string periodo)
         {
             string _sentenciaSql = "USP_GC_BuscarSilaboPeriodo " + codSilabo+","+codCurso+",'" +periodo+"'";

             using (EFContext db = new EFContext(Utility.ObtenerCadena()))
             {
                 return db.Database.SqlQuery<SilaboBE>(_sentenciaSql).ToList(); ;
             }
         }

    }
}
